/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package com.brain.cobranza.manager;
import com.brain.cobranza.dto.PagoDto;
import com.brain.core.manager.*;
import com.brain.core.exception.DAOException;
import com.brain.core.hibernate.dao.DAOGenerico;
import java.io.Serializable;
import java.util.List;
import java.util.Map;
import javax.annotation.Resource;
import org.apache.log4j.Logger;
import org.springframework.stereotype.Service;

/**
 *
 * @author Indra
 */
@Service
public class PagoManager extends ComunManager<PagoDto> implements Serializable {

    private static Logger logger = Logger.getLogger(PagoManager.class);
    private Long idEntidad = 309L;
    @Resource
    private DAOGenerico<PagoDto> springHibernateDao;
    @Resource
    private RecursosManager recursosManager;

    /**
     * Metodo para obtener todas las empresas
     *
     * @return lista de empresas
     * @throws DAOException
     */
    public List<PagoDto> obtenerTodos() throws DAOException {
        return springHibernateDao.listarTodosDtos(PagoDto.class);
    }

    /**
     * Metodo para obtener una empresa por su ID
     *
     * @param id ID de la empresa
     * @return Empresa
     * @throws DAOException
     */
    public PagoDto obtenerPorId(Long id) throws DAOException {
        return springHibernateDao.obtenerDtoPorId(PagoDto.class, id);
    }

    /**
     * Metodo para obtener empresas por un mapa de filtros
     *
     * @param filtros mapa de filtros
     * @return lista de empresas
     * @throws DAOException
     */
    public List<PagoDto> obtenerConFiltro(Map<String, Object> filtros) throws DAOException {
        return springHibernateDao.obtenerDtosConFiltros(PagoDto.class, filtros);
    }

    /**
     * Metodo para obtener empresas por un mapa de filtros y un mapa de orden
     *
     * @param filtros mapa de filtros
     * @param orden mapa de orden
     * @return lista de empresas
     * @throws DAOException
     */
    public List<PagoDto> obtenerConFiltroConOrden(Map<String, Object> filtros, Map<String, String> orden) throws DAOException {
        return springHibernateDao.obtenerDtosConFiltrosConOrden(PagoDto.class, filtros, orden);
    }
    
    public List<PagoDto> obtenerPorDeuda(Long idDeuda) throws DAOException {
        String hql = "select e from PagoDto e where e.deudaClienteDto.id= "+idDeuda;
        
        return springHibernateDao.ejecutarQuery(hql);
    }

    public static Logger getLogger() {
        return logger;
    }

    public static void setLogger(Logger logger) {
        PagoManager.logger = logger;
    }

    public Long getIdEntidad() {
        return idEntidad;
    }

    public void setIdEntidad(Long idEntidad) {
        this.idEntidad = idEntidad;
    }

    public DAOGenerico<PagoDto> getSpringHibernateDao() {
        return springHibernateDao;
    }

    public void setSpringHibernateDao(DAOGenerico<PagoDto> springHibernateDao) {
        this.springHibernateDao = springHibernateDao;
    }

    public RecursosManager getRecursosManager() {
        return recursosManager;
    }

    public void setRecursosManager(RecursosManager recursosManager) {
        this.recursosManager = recursosManager;
    }
}
